package com.xiaotu.storage;

import java.util.Date;

import org.springframework.stereotype.Component;

import com.xiaotu.common.util.Constants;
import com.xiaotu.common.util.DataRedisKeyUtils;
import com.xiaotu.common.util.SepratorUtil;
import com.xiaotu.storage.converter.AConverter;
import com.xiaotu.storage.converter.ConverterFactory;
import com.xiaotu.storage.model.CacheDataModel;

import net.sf.json.JSONObject;
/***
 * 猫眼网大累计分账票房相关
 * @author Administrator
 *
 */
@Component("MovieSplitBoxofficeSummaryStorageProcessor")
public class MovieSplitBoxofficeSummaryStorageProcessor extends AHSetStorageProcessor{

	
	private static final String[] FIELD_ARR = new String[]{
			"id","tvid","tv_dataid","tvName", 
			"resourceSiteId",
            "totalSplitBox",
            "totalViewTimes",
            "productionCost",
            "score",
			"collecttime"};

    private static final String[] CONVERT_ARR = new String[]{
    		AConverter.STRING_CONVERT,AConverter.STRING_CONVERT,AConverter.STRING_CONVERT,AConverter.STRING_CONVERT,
            AConverter.STRING_CONVERT,
            AConverter.NUMBER_CONVERT,AConverter.NUMBER_CONVERT,AConverter.NUMBER_CONVERT,
            AConverter.NUMBER_CONVERT,
            AConverter.TIMESTAMP_CONVERT};

    private static final boolean[] THROW_ARR = new boolean[]{
    		true,true,true,true, true, 
    		true, true, true, true,true
    		};
	
	
	@Override
	protected String getRedisKey(Date date) {
		return DataRedisKeyUtils.getKey(Constants.DataRedisKey.MOVIE_SPLIT_SUMMARY_YYYYMMDD, date);
	}

	@Override
	public String process(JSONObject target, CacheDataModel cacheData, Date date) {
		return this.list2CSVLine(ConverterFactory.convert(target, FIELD_ARR, CONVERT_ARR,
                THROW_ARR), SepratorUtil.SEP_PIPE);
	}

	@Override
	public String getDataType() {
		 return Constants.PageDataType.TV_RECORD;
	}

	@Override
	public String getTaskType() {
		return Constants.SpiderTaskType.MOVIE_BOXOFFICE;
	}
	
}
